## **LAB 3**

## OBJECTIVE: To design and simulate a NOT gate using VHDL, and verify its functionality using a testbench.

## TOOLS USED:

* VHDL (VHSIC Hardware Description Language)
* <https://www.edaplayground.com/> (for simulation)

**THEORY:**

The aim of this lab is to create a NOT gate in VHDL and simulate it using a testbench. The design code describes the logic of the NOT gate, and the testbench applies both possible input combinations to validate the behavior of the gate.

## VHDL CODE

**DESIGN:**

library ieee;

use ieee.std\_logic\_1164.all;

entity notgate is

port( a: in std\_logic;

c: out std\_logic);

end andgate;

architecture behavior of notgate is

begin

c <= not a;

end behavior;

**TESTBENCH**

library ieee;

use ieee.std\_logic\_1164.all;

entity notgate\_tb is

---> no content

end notgate\_tb;

architecture test of notgate\_tb is

component notgate

port(a: in std\_logic;

c: out std\_logic);

end component;

signal ak,ck: std\_logic;

begin

and\_gate: notgate port map(a=>ak,c => ck );

process begin

ak <= '0'; wait for 1 ns;

ak <= '1'; wait for 1 ns;

assert false report "Completed successfully";

wait;

end process;

end test;

Output:

![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAewAAAA9CAYAAABvP1peAAAAAXNSR0IArs4c6QAAAARnQU1BAACxjwv8YQUAAAAJcEhZcwAADsMAAA7DAcdvqGQAAAWOSURBVHhe7d1NTBRnHMfx3/bGBdygCcRAqolW2kQtntxbkUvjjXIwEQ8NXNiLEu574FyqXjBptB7UxEPjzdvKEU9StKlrNbENxrAJNStcONJ5dp59YVmQzM5M5xm/n2STZ+YZXrL/eZ7/PC/JZLY9AgAAiZaZnp5OVcJeWLilfH7aHsEVxM1NxM09xMxNJm5f2DIAAEgwEjYAAA4gYQMA4AASNgAADkj3prOR55ofX1KXKW/l9Gj2jIrVCiRNI26rKiw8Vp9/enfcrhS1cP6NXy5fVH5u0C97Jgq3lLM/WH46rbl7fhnRad3ANHrtocZOHtZSflT37blP2Ttum7o6/0BfVRtwVn/9dkk3F6sVtO0OdBoz//qKPSJmcUn5pjOv4x9f1+/ejWluzvzKusYKq7YOiWYacy1uzY3aNPizR+p1jzaXNH9ts1plOpFvNy/7P5O/rI2zD3V1pFqFOJjYeB3K9xpS2Z46iP3iNlF4oJ4Vex/kc+oZL2qiWkPbDkXAmBkmSftx2flgTMyild6EfeW1+raONG7E90e01ffa3jxw0ejpkro2svUEXvxwWF0Df2vUe6r/ZqCijQ/dtqZbHzYqGjztJ3PEYPGMZr2OePZG1p44iP3itqrjfVltvPdrpEPa2Hqj41e8Im07HIFith9iFrXPZw170buRbBEJ17WkMe/Jf2Gh9nS+B9PobbFVeTOsTghx2jtuJpnbYivaduz6zpv2eas+w9UeMQvb55OwRyrqsUUk2aDmatNmT6Xc/HNvBL2Ho+v+elgbfd2NNTa4Y++4bap3rwZM245V8cYlO+V9WasDD1QwI+i2iFnY0puw751UuWu9sXnJdO7lkwfeCIPkKb4Y0lZPpZ7AR3v/1da7Yyp6T/J/vsuqp7f2tG86iqxWX9SmWpEEZnPZzlmT/eI2qLdlr1M/6tdIH9XTdUJvzXopbTs2u2O2H2IWNXaJIxHqcWuOWesuU4Nd4onSPm41O+Pnx+fErt3I7BKPV6cxa45XaxskZtExcUv3lLjdVFGdvmlzc5gv4KC41hfVtXXNMcu3JGvjnj++rtbv6Cik+3O1n2t0+mn+zpJwbd2OuNU+jfiZ33l/7qLKzRuPrNa4Nf5+t27O7v5dVfbvGe3adjtJ+L6ScG3dJ2JmmMTcGrPmeDW3Qf9/+HTMTJ3Zp3LQZO3a9xvVtcbns4YN4H81UXgsrTCqcg4xSwwSNoBYmJEZyxTuIWbJQcIGAMABJGwAAByQyl3iAACkTeoSNgAAacSUOAAADsh4H0bYAAAkHAkbQEeGnw3bEoAokbABBGaS9fK5ZXsEIEqsYQMA4AASNgAADiBhAwDgABI2AAAOIGEDAOAAEjYAAA4InrBnnqiyva3t2qd021YAAICwBU/Y1y8om8koU/3cUelUTqRsAACi0dGU+O1SbYQ9qSF7DgAAhC9wwp5drGhSdxojbHseAACEL3DCHuo/pI9rNk3PHFO/XwIAABEInLCnflmUvvvJnxIvSMuvhjS5/ZJ1bAAAIsDLPwAExss/gPh0tOkMAADEI70j7G0mDoCoDS+f0/LwM68nMV0JgCgxJQ4AgAOYEgcAwAEkbAAAHJDaKXGzexVAPNgpDkSPNWwAwZnNnWw4A2LBlDgAAA4gYQMA4AASNgAADiBhAwDggMAJ27wL++Wv9gAAAESKETYAAA7oMGHf1kvzek3zKfFiTQAAotJRwh76MaelTEaZzB2VTk0yRQ4AQEQ6Stilu19rqlqa0tIrqf/L2eoRAAAIV6hr2Gv/zNsSAAAIU2dT4uftuvXME/1w6qPW/vAPAQBAuDqbElfO33D284jW7mZ14bqtAAAAoeLlHwCC4+UfQGxCXcMGAADRYIQNIDgzwgYQCxI2AAAOYEocAIDEk/4DMOS6W8SWnSgAAAAASUVORK5CYII=)

CONCLUSION:

The NOT gate was successfully simulated. The output matched the expected behavior where ck is the inverse of ak for all input combinations. The use of a simple testbench allowed for effective verification of the circuit behavior in a VHDL simulation environment.